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Abstract 

It is of great interest to develop a framework containing a library of the main building blocks 
of common use to neutrosophic data. This framework would save much of the routine work 
that is needed to build most types of neutrosophic data. In this paper, we would like to 
introduce model neutrosophic data sets. The use of object oriented programming techniques 
and concepts as they may apply to the design and development a new framework to 
implement neutrosophic data operations 


Keywords: Neutrosophicdata, software programs, neutrosophic database. AMS Subject 
Classification: 03B99, 03E99 
1 Introduction 
In real-life problems, the data associated are often imprecise, or non-deterministic. All real 
data cannot be precise because of their fuzzy nature. Imprecision can be of many types: non- 
matching data values, imprecise queries, inconsistent data misaligned schemas, etc. The 
fundamental concepts of neutrosophic set, introduced by Smarandache in [8, 9] and Salamaet 
al. in [1, 2, 3, 4, 5, 6 7, 10, 11, 12, 13, 15, 16], provides a natural foundation for treating 
mathematically the neutrosophic phenomena which exist pervasively in our real world and 
for building new branches of neutrosophic mathematics. 
In this paper, we have developed an Excel package to be utilized for calculating neutrosophic 
data and analyze them. We have used Excel as it is a powerful tool that is widely accepted 
and used for statistical analysis. In this paper, we have developed an Excel package to be 
utilized for calculating neutrosophic data and analyze them. The use of object oriented 
programming techniques and concepts as they may apply to the design and development a 
new framework to implement neutrosophic data operations, the c# programming language, 
NET Framework and Microsoft Visual Studio are used to implement the neutrosophic 
classes. 


2 Related Works 
We recollect some relevant basic preliminaries, and in particular, the work of Smarandache in 
[8, 9], and Salamaet al. [1, 2, 3, 4, 5, 6, 7, 10, 11, 12, 13, 15, 16]. The c# programming 
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language, NET Framework and Microsoft Visual Studio are used to implement the 
neutrosophic classes. 


3 A Proposed frameworks 

Fig. 1 shows Class Diagram of the implemented package. Fig. 2 presents a working example 
of the package interface calculating the complement. Our implemented neutrosophic package 
can calculate Intersection, Union, and Complement of the nuetrosophic set. Fig. 3 presents 
our neutrosphic package capability to draw figures of presented neutrosphic set. Fig. 4 
presents charting of Union operation calculation, and Fig. 5 Intersection operation 
nuetrosophic set are characterized by its efficiency as it takes into consideration the three 
data items: True, Indeterminate and False We introduce the neutrosophic package class 
diagram. 


4 Neutrosophic Operations Codes 

Object oriented programming languages offer benefits toward the approach and design of 
software programs. The Primary advantages include code reusability, rapid prototyping, as 
well as, lower software design and maintenance costs. The use of object oriented 
programming techniques and concepts as they may apply to the design and development a 
new framework to implement Neutrosophic operations. The c# programming language, .NET 
Framework and Microsoft Visual Studio is used to implement.In the following, some c# 
code attached are used to explain the concept described inabove Section more 
clearly.theNeutrosophicclassess fuzzy operations can copy the operand fuzzy 
set’smembership function class to create resultant fuzzy set. 
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Fig. 1. Neutrosophic package class diagram 
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Fig. 2. Neutrosophic package interface and calculating complement 
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Fig. 3.Neutrosophicchart 
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Fig. 5. Neutrosophic package intersection chart 


usingSystem.Collections.Generic; 
usingSystem.Linq; 
usingSystem.Text; 
namespaceRibbonCustomize 


{ 


classNeutrosophic ValueException:Exception 


{ 
publicNeutrosophic ValueException() 
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: base(""Neutrosophic value must be between 0 and 1") 


{ 
} 
} 


classNeutrosophicSet:List<Neutrosophic> 


{ 
publicNeutrosophicSet Complement! () 


{ 
NeutrosophicSetcomplementSet = newNeutrosophicSet(); 
foreach (Neutrosophic n inthis) 


complementSet.Add(n.Complement1()); 


} 


returncomplementSet; 


} 
publicNeutrosophicSet Complement2() 


{ 


NeutrosophicSetcomplementSet = newNeutrosophicSet(); 
foreach (Neutrosophic n inthis) 


complementSet.Add(n.Complement2()); 


returncomplementSet; 


} 
publicNeutrosophicSet Complement3() 


{ 


NeutrosophicSetcomplementSet = newNeutrosophicSet(); 
foreach (Neutrosophic n inthis) 


complementSet.Add(n.Complement3()); 
} 


returncomplementSet; 


} 


publicBoolean 


BelongTo1(NeutrosophicSetnSet) 
{ 


for (inti = 0; i<this.Count; i++) 


{ 
if (!this[i].BelongTo1 (nSet[i])) 
returnfalse; 


} 


returntrue; 


} 
publicBoolean BelongTo2(NeutrosophicSetnSet) 
{ 


for (inti = 0; i<this.Count; i++) 


{ 
if (!this[i].BelongTo2(nSet[i])) 
returnfalse; 


} 
returntrue; 
} 
} 


classNeutrosophic 


{ 
double t, i, f; 
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publicNeutrosophic(doublet,doublei,double f) 


get 


returnConvert.ToDouble( Math.Round( t,4)); 
} 


set 


{ 
if (t<0||t> 1) 
thrownewNeutrosophic ValueException(); 
t = value; 


} 


} 
publicdouble I 
get 


returnConvert.ToDouble(Math.Round@, 4)); 
} 


set 


if (value< 0 || value> 1) 
thrownewNeutrosophic ValueException(); 
i = value; 


} 


} 
publicdouble F 
get 


returnConvert.ToDouble(Math.Round(f, 4)); ; 
} 


set 


if (value< 0 || value> 1) 
thrownewNeutrosophic ValueException(); 
f = value; 
} 

} 
publicNeutrosophic Complement! () 

{ 
Neutrosophic complement = newNeutrosophic(1 - T, 1 - i, 1 - F); 
return complement; 


} 
publicNeutrosophic Complement2() 


{ 
Neutrosophic complement = newNeutrosophic(F,i, T); 
return complement; 

} 
publicNeutrosophic Complement3() 

{ 
Neutrosophic complement = newNeutrosophic(F, i, T); 
return complement; 


} 
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publicbool BelongTo1(Neutrosophic n) 


{ 
return (this. T<= n.T& &this. [<= n.I[&&this.F>= n.F); 


} 
publicbool BelongTo2(Neutrosophic n) 

{ 
return (this. T<= n.T& &this. >= n.I[&&this.F>= n.F); 

} 

} 

} 
using System; 
usingSystem.Collections.Generic; 
usingSystem.Linq; 
usingSystem.Text; 
usingSystem.Windows.Forms.DataVisualization.Charting; 
usingSystem.Drawing; 
using Excel = Microsoft.Office.Interop.Excel; 
namespaceRibbonCustomize 


{ 


classNeutrosophicSetOperations 


publicstaticvoid Chart(ChartmyChart, paramsNeutrosophicSet[] nsArray) 
{ 

intnsOrder = 1; 

intnCount = nsArray[0].Count; 

intlabelIndex = 0; 

foreach (NeutrosophicSet ns innsArray) 


{ 
string T= "T"; 
string I= "I"; 
string F="F"; 
if (nsArray.Length> 1) 
{ 
T= "T" + nsOrder; 
T= "I" + nsOrder; 
F="F" + nsOrder; 
} 
myChart.Series.Add(T); 
myChart.Series.Add(1); 
myChart.Series.Add(F); 


myChart.Series[T].Color = Color.Red; 
myChart.Series[I].Color = Color.Green; 
myChart.Series[F].Color = Color.Blue; 


intyValue = 97; 
foreach (Neutrosophic n in ns) 

{ 
string c = Convert.ToChar(y Value). ToString(); 
myChart.Series[T].Points.AddXY(c, n.T); 
myChart.Series[I].Points.AddX Y(c, n.D); 
myChart.Series[F].Points.AddXY(c, n.F); 
yValue++; 

} 
FontFamily family = newFontFamily("Times New Roman"); 
Fontfont = newFont(family, 12, FontStyle.Bold | FontStyle.Italic); 
myChart.Series[T].Points[0].Label = T; 
myChart.Series[T].Points[0].Font = font; 
myChart.Series[I].Points[0].Label = I; 
myChart.Series[I].Points[0].Font = font; 
myChart.Series[F].Points[0].Label = F 


a 
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myChart.Series[F].Points[0].Font = font; 
nsOrder++; 
} 
foreach (SeriesserinmyChart.Series) 
{ 
ser.BorderWidth = 2; 
ser.ChartType = SeriesChartType.Spline; 
} 
} 
publicstaticNeutrosophicSet Intersect 1(paramsNeutrosophicSet[] nSetArray) 
{ 
intneutroSophicCount = nSetArray[0].Count; 
NeutrosophicSetintersectSet = newNeutrosophicSet(); 
for Gint x = 0; x <neutroSophicCount; x++) 


{ 
double t= 1,i1=1,f=1; 
for Gint y = 0; y <nSetArray.Length; y++) 
{ 
t *= nSetArray[y][X].T; 
i *= nSetArray[y][x].I; 
f *= nSetArray[y][x].F; 
} 
Neutrosophicneutro = newNeutrosophic(t, i, f); 
intersectSet.Add(neutro); 
} 
returnintersectSet; 
} 
publicstaticNeutrosophicSet Intersect2(paramsNeutrosophicSet[] nSetArray) 
{ 
intneutroSophicCount = nSetArray[0].Count; 
NeutrosophicSetintersectSet = newNeutrosophicSet(); 
for (int x = 0; x <neutroSophicCount; x++) 


{ 
doubleminT = nSetArray[0][x].T; 
doubleminI = nSetArray[0][x]. 
doublemaxF = nSetArray[0][x].F; 
for (int y = 1; y <nSetArray.Length; y++) 


{ 
if (nSetArray[y][x].T <minT) 
minT = nSetArray[y][x].T; 
if (nSetArray[y][x].I <minlI) 
minI = nSetArray[y][x]-I; 
if (nSetArray[y][x].F >maxF) 
maxF = nSetArray[y][x].F; 

} 


intersectSet.Add(newNeutrosophic(minT, minI, maxF)); 
} 
returnintersectSet; 
} 
publicstaticNeutrosophicSet Intersect3(paramsNeutrosophicSet[] nSetArray) 
{ 
intneutroSophicCount = nSetArray[0].Count; 
NeutrosophicSetintersectSet = newNeutrosophicSet(); 
for (int x = 0; x <neutroSophicCount; x++) 


{ 
doubleminT = nSetArray[0][x].T; 
doublemaxI = nSetArray[0][x].I; 
doublemaxF = nSetArray[0][x].F; 
for Gint y = 1; y <nSetArray.Length; y++) 
{ 
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if (nSetArray[y][x].T yee, 
minT = nSetArray[y][x].T 


if (nSetArray[y][x].I simael) 
maxI = nSetArray[y][x]_I; 
if (nSetArray[y][x].F snake) 


maxF = nSetArray[y][x].F; 
} 


intersectSet.Add(newNeutrosophic(minT, maxI, maxF)); 

bint oe 

sa aagistesaine Union 1 (paramsNeutrosophicSet[] nSetArray) 
ee coon = nSetArray[0].Count; 

NeutrosophicSetintersectSet = newNeutrosophicSet(); 


for (int x = 0; x <neutroSophicCount; x++) 


{ 
doublemaxT = nSetArray[0][x].T; 
doublemaxI = nSetArray[0][x].I; 
doubleminF = nSetArray[0][x].F; 
for (int y = 1; y <nSetArray.Length; y++) 
{ 


if (nSetArray[y][x].T >maxT) 
maxT = nSetArray[y][x].T; 

if (nSetArray[y][x].I >maxI) 
maxI = nSetArray[y][x].I; 

if (nSetArray[y][x].F <minF) 
minF = nSetArray[y][x].F 


intersectSet.Add(newNeutrosophic(maxT, maxI, minF)); 
} 
returnintersectSet; 
} 
publicstaticNeutrosophicSet Union2(paramsNeutrosophicSet[] nSetArray) 
{ 
intneutroSophicCount = nSetArray[0].Count; 
NeutrosophicSetintersectSet = newNeutrosophicSet(); 
for (int x = 0; x <neutroSophicCount; x++) 


{ 
doublemaxT = nSetArray[0][x].T; 
doubleminI = nSetArray[0][x]. 
doubleminF = nSetArray[0][x].F; 
for (int y = 1; y <nSetArray.Length; y++) 


{ 
if (nSetArray[y][x].T >maxT) 
maxT = nSetArray[y][x].T; 
if (nSetArray[y][x].I <minI) 
minI = nSetArray[y][x]-I; 
if (nSetArray[y][x].F <minF) 
minF = nSetArray[y][x].F; 

} 


intersectSet.Add(newNeutrosophic(maxT, minI, minF)); 


} 


returnintersectSet; 


} 


publicstaticNeutrosophicSetGetNeutrosophicSet(Excel. Range range) 


{ 


NeutrosophicSetnSet = newNeutrosophicSet(); 
string[] arrVal = newstring[range.Count]; 
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int index = 0; 
foreach (Excel.Range r inrange.Cells) 


{ 
arrVal[index++] = (Convert.ToString(r. Value2)); 


for (int r= 0; r <arrVal.Length; r++) 
{ 
string[] strArr = arrVal[r].Split(’,’); 
nSet.Add(newNeutrosophic(double.Parse(strArr[0]), double.Parse(strArr[1]), double.Parse(strArr[2]))); 
} 
returnnSet; 
} 
publicstaticList<NeutrosophicSet>GetNeutrosophicSetList(Excel.Range range) 
{ 
List<NeutrosophicSet>nSetList = newList<NeutrosophicSet>(); 
boolstartFlag = true, againFlag = false; 
charstartCol = '', currentCol ='', prevCol = ''; 
intnSetIndex = 0; 
foreach (Excel.Range r inrange.Cells) 


{ 
if (startFlag) 


{ 
startCol = r.Address.ToString()[1]; 
startFlag = false; 
nSetList.Add(newNeutrosophicSet()); 
prevCol = startCol; 


} 


{ 
currentCol = r.Address.ToString()[1]; 


if (currentCol == startCol) 
{ 
againFlag = true; 
nSetIndex = -1; 
} 
if (againFlag) 
nSetIndex++; 
elseif (currentCol != prevCol) 
{ 
prevCol = currentCol; 
nSetList.Add(newNeutrosophicSet()); 
nSetIndex++; 
} 


} 
stringcell Value = (Convert.ToString(r. Value2)); 


string[] strArr = cell Value.Split(’,’); 
Neutrosophic n = newNeutrosophic(double.Parse(strArr[0]), double.Parse(strArr[1]), double.Parse(strArr[2])); 
nSetList[nSetIndex].Add(n); 
} 
returnnSetList; 
} 
} 


else 


} 

using System; 
usingSystem.Collections.Generic; 
usingSystem.Linq; 

usingSystem.Text; 
usingMicrosoft.Office.Tools.Ribbon; 

using Excel = Microsoft.Office.Interop.Excel; 
usingSystem.Windows.Forms; 


R S. Publication, rspublicationhouse @ gmail.com Page 171 


International Journal of Computer Application Issue 4, Volume 5 (Sep - Oct 2014) 
Available online on http://www.rspublication.com/ijca/ijca_index.htm ISSN: 2250-1797 


usingSystem.Collections; 

usingMicrosoft.Office. Tools.Excel; 

usingFormChart = System.Windows.Forms. Data Visualization.Charting. Chart; 
usingSystem.Windows.Forms.DataVisualization.Charting; 
usingSystem.Drawing; 

namespaceRibbonCustomize 


{ 
publicpartialclassRibbon1 


{ 
privatevoid Ribbon1_Load(object sender, RibbonUIEventArgs e) 


{ 

} 
FormChartmyChart; 
privatevoidbtnChart_Click(object sender, RibbonControlEventArgs e) 

{ 
Excel.Rangeselectedrange = Globals.ThisAddIn. Application.Selection; 
myChart = newFormChart(); 
Worksheetworksheet = 
Globals.Factory.GetVstoObject(Globals.ThisAddIn. Application. Active Workbook.ActiveSheet); 
Excel.Range cells = worksheet.Range["F2", "R20"]; 
worksheet.Controls.AddControl(myChart, cells, "MyChart"); 
//myChart.Legends.Add(new Legend("LG")); 
myChart.ChartAreas.Add("area"); 
myChart.ChartAreas["area"].Axis Y.Minimum = 0; 
myChart.ChartAreas["area"].Axis Y.Maximum = 1; 
myChart.ChartAreas["area"].Axis Y.Title = "Neutrosophic Set"; 
if (selectedrange.Columns.Count == 1) 

{ 

NeutrosophicSetnSet = NeutrosophicSetOperations.GetNeutrosophicSet(selectedrange); 
NeutrosophicSetOperations.Chart(myChart, nSet); 


else 

{ 
List<NeutrosophicSet>nSetList = NeutrosophicSetOperations.GetNeutrosophicSetList(selectedrange); 
NeutrosophicSetOperations.Chart(myChart, nSetList.ToArray()); 


Buttonbtn = newButtonQ; 

btn.Text = "X"; 

btn. Width = 30; 

btn.FlatStyle = FlatStyle.Flat; 
btn.FlatAppearance.BorderSize = 0; 

btn.Location = newPoint(myChart.Width - btn. Width, 0); 
myChart.Controls.Add(btn); 

btn.Click += btn_Click; 


Labellbl = newLabel(); 

Ibl.Text = "Chart type"; 

Ib].TextAlign = ContentAlignment.MiddleRight; 

Ib].Location = newPoint(10, myChart.Height - 1bl.Height - 5); 

ComboBoxcmb = newComboBox(); 

cmb.DropDownStyle = ComboBoxStyle.DropDownList; 

cmb.Location = newPoint(Ibl.Location.X + Ibl.Width + 2, myChart.Height - lb]. Height - 5); 
cmb.SelectedIndexChanged += cmb_SelectedIndexChanged; 

foreach (string value inEnum.GetNames(typeof(SeriesChartType))) 


{ 
cmb.Items.Add(value); 


} 
myChart.Controls.Add(Ibl); 
myChart.Controls.Add(cmb); 

} 
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voidbtn_Click(object sender, EventArgs e) 

{ 
Worksheetworksheet = 
Globals.Factory.GetVstoObject(Globals.ThisAddIn. Application. Active Workbook.ActiveSheet); 
worksheet.Controls.RemoveAt(0); 


voidemb_SelectedIndexChanged(object sender, EventArgs e) 
{ 
ComboBoxcmb = (ComboBox)sender; 
SeriesChartT ype type = (SeriesChartlype)Enum.Parse(typeof(SeriesChartT ype), cmb.SelectedItem.ToString()); 
foreach (SeriesserinmyChart.Series) 
ser.ChartType = type; 
} 
privatevoidbtnComplement_Click(object sender, RibbonControlEventArgs e) 
{ 
Excel.Rangeselectedrange = Globals.ThisAddIn.Application.Selection; 
NeutrosophicSetnSet = NeutrosophicSetOperations.GetNeutrosophicSet(selectedrange); 
NeutrosophicSet nSetcom! = nSet.Complement1(); 
NeutrosophicSet nSetcom2 = nSet.Complement2(); 
NeutrosophicSet nSetcom3 = nSet.Complement3(); 
PrintResult("F", "Complement may be", 19, nSetcom1); 
PrintResult("G", "Complement may be", 19, nSetcom2); 
PrintResult("H", "Complement may be", 19, nSetcom3); 
} 
voidPrintResult(stringcolumnName, stringmsg, intcolumnWidth, NeutrosophicSetnSet) 
{ 
WorksheetactiveWorksheet = 
Globals.Factory.GetVstoObject(Globals.ThisAddIn. Application. Active Workbook.ActiveSheet); 
Excel.Range rangeCom1 = activeWorksheet.get_Range(columnName + "1"); 
rangeCom1.Value2 = msg; 
rangeCom1.EntireColumn.Column Width = columnWidth; 
int f = 2; 
foreach (Neutrosophic n innSet) 


{ 


Excel.RangerangeComValue = activeWorksheet.get_Range(columnName + (f++)); 


win, 


rangeComValue. Value2 = ""; 


rangeComValue. Value2 += "," + n.T; 
rangeComValue. Value2 += "," + n.I; 
rangeComValue. Value2 += "," + n.F; 


rangeComValue. Value2 = ((string)rangeCom Value. Value2).Remove(0, 1); 


} 
//for (int r = 0; r <arrayToPrint.GetLength(0); r++) 
/I{ 
// Excel.RangerangeComValue = activeWorksheet.get_Range(columnName + (f++)); 
// rangeComValue.Value2 = ""; 
// for (int c = 0; c <arrayToPrint.GetLength(1); c++) 


I} { 

// rangeComValue. Value2 += "," + arrayToPrint[r, c]; 

// } 

// rangeComValue.Value2 = ((string)rangeComValue. Value2).Remove(0, 1); 
/1} 


} 


privatevoidbtnIntersect_Click(object sender, RibbonControlEventArgs e) 

{ 
Worksheetactive Worksheet = 
Globals.Factory.GetVstoObject(Globals.ThisAddIn. Application. Active Workbook.ActiveSheet); 
activeWorksheet.Range["F1", "H26"].ClearQ; 
Excel.Range range = Globals.ThisAddIn. Application. Selection; 
List<NeutrosophicSet>nSetList = NeutrosophicSetOperations.GetNeutrosophicSetList(range); 
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NeutrosophicSet setl = NeutrosophicSetOperations.Intersect1(nSetList.ToArray()); 
NeutrosophicSet set2 = NeutrosophicSetOperations.Intersect2(nSetList.ToArray()); 
NeutrosophicSet set3 = NeutrosophicSetOperations.Intersect3(nSetList.ToArray()); 
PrintResult("F", "Intersect may be", 18, set1); 
PrintResult("G", "Intersect may be", 18, set2); 
PrintResult("H", "Intersect may be", 18, set3); 


} 


privatevoidbtnUnion_Click(object sender, RibbonControlEventArgs e) 


{ 


Worksheetactive Worksheet = 
Globals.Factory.GetVstoObject(Globals.ThisAddIn. Application. Active Workbook.ActiveSheet); 
activeWorksheet.Range["F1", "H26"].ClearQ; 

Excel.Range range = Globals.ThisAddIn. Application. Selection; 

List<NeutrosophicSet>nSetList = NeutrosophicSetOperations.GetNeutrosophicSetList(range); 

NeutrosophicSet setl = NeutrosophicSetOperations.Union1(nSetList.ToArray()); 

NeutrosophicSet set2 = NeutrosophicSetOperations.Union2(nSetList.ToArray()); 

PrintResult("F", "Intersect may be", 18, set1); 

PrintResult("G", "Intersect may be", 18, set2); 


} 
} 
} 


5 Conclusions and Future Work 


The advantage to using object-oriented modelling of Neutrosophics sets is that we avoid 
problems of the distortion problem in general. Furthermore, because the result of 
Neutrosophic set contains all the Neutrosophic membership functions and operators involved, 
the Neutrosophic set operations are traceable. In addition, due to our object-oriented 
structure, the Neutrosophicmembership functions and operators can be reused and managed 
in a flexible way. Although increasing cascaded operations will increase the number of 
computation, this overhead is not large. On the other hand, grades of membership will only 
be calculated when needed and avoid unnecessary computation of traditional approaches. 
Therefore in general the performance of our approach will be better. The traditional method 
of modelling neutrosophic data sets with a pair of arrays to store elements and their grades of 
membership may cause distortion if sampling is not enough. Our object-oriented model 
solves this problem. Our program not only solves the distortion problem, but also provides a 
flexible and efficient way to develop full-scaled fuzzy logic systems.In future studies we will 
develop some software programs to deal with the statistical analysis of the neutrosophic data 
in [1-16]. 
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